/***************************************************************************/
/* Procedimiento:  Reparacion_EmergenciaInsertar
/* Descripcion:   Insertar o Modifica una fila en la tabla Reparacion_Emergencia
/* Parametros:    ?InfoParametros
/*                pTransaccion. Numero identificador de la Transaccion
/*                pMensaje. Mensaje de comfirmacion o excepcion
/* Comentarios:         
/****************************************************************************/

PROCEDURE  Reparacion_EmergenciaInsertarModificar(pnidDocumento NUMBER, pfecha_Inicio VARCHAR2, pfecha_Fin VARCHAR2, 
								pnidEmpCesionaria NUMBER, pequipo_Cargo VARCHAR2, pubiacion NUMBER, 
								pequipo_Reparar VARCHAR2, pdescripcion VARCHAR2, pobservaciones VARCHAR2, 
								 pTransaccion OUT NUMBER, pMensaje OUT VARCHAR2)
AS
vExisteRegistro NUMBER(1);
BEGIN
  SELECT count(*)
  INTO   vExisteRegistro
  FROM   Reparacion_Emergencia
  WHERE  nidDocumento=pNidDocumento;
  
  IF vExisteRegistro=0 THEN
    INSERT INTO Reparacion_Emergencia
	           (nid, nidDocumento, fecha_Inicio, 
				fecha_Fin, nidEmpCesionaria, equipo_Cargo, 
				ubiacion, equipo_Reparar, descripcion, 
				observaciones)
    VALUES     (seq_Reparacion_Emergencia.nextval, pnidDocumento, to_date(pfecha_Inicio,'DD/MM/YYYY HH24:MI:SS'), 
				to_date(pfecha_Fin,'DD/MM/YYYY HH24:MI:SS'), pnidEmpCesionaria, pequipo_Cargo, 
				pubiacion, pequipo_Reparar, pdescripcion, 
				pobservaciones);
  ELSE
    UPDATE Reparacion_Emergencia
    SET    nidDocumento=pnidDocumento, fecha_Inicio=to_date(pfecha_Inicio,'DD/MM/YYYY HH24:MI:SS'), 
			fecha_Fin=to_date(pfecha_Fin,'DD/MM/YYYY HH24:MI:SS'), nidEmpCesionaria=pnidEmpCesionaria, equipo_Cargo=pequipo_Cargo, 
			ubiacion=pubiacion, equipo_Reparar=pequipo_Reparar, descripcion=pdescripcion, 
			observaciones=pobservaciones
    WHERE  nidDocumento=pNidDocumento;
  END IF;
  
  COMMIT;
  pTransaccion := 1;
  pMensaje := 'Terminado OK';
  dbms_output.put_line('Terminado OK');

EXCEPTION
  WHEN OTHERS THEN
    pTransaccion := 0;
    pMensaje := 'Error en  Reparacion_Emergencia_InsertarModificar:' || SQLCODE || ' Mensaje: ' || sqlerrm;
    dbms_output.put_line('Error en  Reparacion_Emergencia_InsertarModificar:' || SQLCODE || ' Mensaje: ' || sqlerrm);
END;
